<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>物料转移记录</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <link rel="stylesheet" href="./lib/layui-v2.6.3/css/layui.css" media="all">
    <link rel="stylesheet" href="./css/public.css" media="all">
</head>
<body>
<div class="layuimini-container">
    <div class="layuimini-main">

        <fieldset class="table-search-fieldset">
            <legend>搜索信息</legend>
            <div style="margin: 10px 10px 10px 10px">
                <form class="layui-form layui-form-pane" action="">
                    <div class="layui-form-item">
                        <div class="layui-inline">
                            <label class="layui-form-label">仓库</label>
                            <div class="layui-input-inline">
                                <select name="warehouseId" lay-filter="warehouseSelect">
                                    <option value="">请选择仓库</option>
                                </select>
                            </div>
                        </div>
                        <div class="layui-inline">
                            <label class="layui-form-label">库位</label>
                            <div class="layui-input-inline">
                                <select name="locationId" id="locationSelect" lay-filter="locationSelect">
                                    <option value="">请选择库位</option>
                                </select>
                            </div>
                        </div>
                        <div class="layui-inline">
                            <label class="layui-form-label">物料名称</label>
                            <div class="layui-input-inline">
                                <input type="text" name="materialName" autocomplete="off" class="layui-input">
                            </div>
                        </div>
                        <div class="layui-inline">
                            <button type="submit" class="layui-btn layui-btn-primary" lay-submit lay-filter="data-search-btn">
                                <i class="layui-icon"></i> 搜 索
                            </button>
                        </div>
                    </div>
                </form>
            </div>
        </fieldset>



        <script type="text/html" id="toolbarDemo">
            <div class="layui-btn-container">
                <button class="layui-btn layui-btn-normal layui-btn-sm data-add-btn" lay-event="add"> 添加 </button>
                <button class="layui-btn layui-btn-sm layui-btn-danger data-delete-btn" lay-event="delete"> 删除 </button>
            </div>
        </script>

        <table class="layui-hide" id="currentTableId" lay-filter="currentTableFilter"></table>

        <script type="text/html" id="currentTableBar">
            <a class="layui-btn layui-btn-normal layui-btn-xs data-count-edit" lay-event="edit">编辑</a>
            <a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete" lay-event="delete">删除</a>
        </script>
    </div>
</div>
<script src="./lib/layui-v2.6.3/layui.js" charset="utf-8"></script>
<script>
    layui.use(['form', 'table'], function () {
        var $ = layui.jquery,
            form = layui.form,
            table = layui.table;
        // 获取仓库列表
        function loadWarehouses() {
            $.ajax({
                url: '/transfer/getTransferWarehouses',
                type: 'GET',
                success: function (res) {
                    if (res.code === 0) {
                        var warehouseSelect = $('select[name="warehouseId"]');
                        warehouseSelect.empty();
                        warehouseSelect.append('<option value="">请选择仓库</option>');

                        res.data.forEach(function (warehouse) {
                            warehouseSelect.append('<option value="' + warehouse.warehouseId + '">' + warehouse.warehouseName + '</option>');
                        });

                        form.render('select'); // 重新渲染下拉框
                    } else {
                        layer.msg('获取仓库列表失败：' + res.msg);
                    }
                },
                error: function () {
                    layer.msg('网络异常，请稍后再试');
                }
            });
        }

// 页面加载时获取仓库列表
        $(document).ready(function () {
            loadWarehouses();
        });

        table.render({
            elem: '#currentTableId',
            url: '/transfer/list',
            method: 'post',
            parseData: function (res) {
                return {
                    "code": res.code === 0 ? 0 : 1,
                    "msg": res.msg,
                    "count": res.data.total,
                    "data": res.data.list
                };
            },
            toolbar: '#toolbarDemo',
            defaultToolbar: ['filter', 'exports', 'print', {
                title: '提示',
                layEvent: 'LAYTABLE_TIPS',
                icon: 'layui-icon-tips'
            }],
            cols: [[
                {type: "checkbox", width: 50},
                {field: 'id', width: 80, title: '序号'},
                {field: 'locationPreName', width: 150, title: '转移前位置'},
                {field: 'locationAfterName', width: 150, title: '转移后位置'},
                {field: 'materialCode', width: 120, title: '物料编号'},
                {field: 'materialName', width: 120, title: '物料名称'},
                {field: 'quantity', width: 80, title: '数量'},
                {field: 'materialUnit', width: 80, title: '单位'},
                {field: 'transferTime', width: 150, title: '记录时间', templet: function(d) {
                        return d.transferTime;
                    }},
                {title: '操作', minWidth: 150, align: "center", toolbar: '#currentTableBar'}
            ]],
            limits: [10, 15, 20, 25, 50, 100],
            limit: 15,
            page: true,
            skin: 'line'
        });

        // 监听仓库下拉框变化
        form.on('select(warehouseSelect)', function (data) {
            var warehouseId = data.value;

            if (!warehouseId) {
                $('#locationSelect').empty();
                $('#locationSelect').append('<option value="">请选择库位</option>');
                form.render('select');
                return;
            }

            // 请求后端接口获取该仓库下的库位信息
            $.ajax({
                url: '/transfer/getTransferLocation',
                type: 'GET',
                data: { warehouseId: warehouseId },
                success: function (res) {
                    if (res.code === 0) {
                        var locationSelect = $('#locationSelect');
                        locationSelect.empty();
                        locationSelect.append('<option value="">请选择库位</option>');

                        res.data.forEach(function (location) {
                            locationSelect.append('<option value="' + location.storageLocationId + '">' + location.storageLocationName + '</option>');
                        });

                        form.render('select'); // 重新渲染下拉框
                    } else {
                        layer.msg('获取库位失败：' + res.msg);
                    }
                },
                error: function () {
                    layer.msg('网络异常，请稍后再试');
                }
            });
        });


        // 监听搜索操作
        form.on('submit(data-search-btn)', function (data) {
            // 执行搜索重载
            table.reload('currentTableId', {
                page: { curr: 1 },
                where: {
                    page: 1,
                    limit: 15,
                    warehouseId: data.field.warehouseId,
                    locationId: data.field.locationId,
                    materialName: data.field.materialName
                }
            }, 'data');

            return false;
        });

        /**
         * toolbar监听事件
         */
        table.on('toolbar(currentTableFilter)', function (obj) {
            if (obj.event === 'add') {  // 监听添加操作
                var index = layer.open({
                    title: '添加记录',
                    type: 2,
                    shade: 0.2,
                    maxmin:true,
                    shadeClose: true,
                    area: ['100%', '100%'],
                    content: 'warehouse-transfer-add.html',
                });
                $(window).on("resize", function () {
                    layer.full(index);
                });
            }
         else   if (obj.event === 'delete') {
                var checkStatus = table.checkStatus('currentTableId'),
                    data = checkStatus.data;

                if (data.length === 0) {
                    layer.msg('请选择要删除的数据');
                    return;
                }

                const ids = data.map(item => item.id);

                layer.confirm('确定删除选中的 ' + data.length + ' 条记录？', function (index) {
                    const loadingIndex = layer.load(2);
                    $.ajax({
                        url: '/transfer/delete',
                        type: 'DELETE',
                        contentType: 'application/json',
                        data: JSON.stringify(ids),
                        success: function (res) {
                            layer.close(loadingIndex);
                            if (res.code === 0) {
                                layer.msg('删除成功');
                                table.reload('currentTableId');
                            } else {
                                layer.msg('删除失败：' + res.msg);
                            }
                        },
                        error: function () {
                            layer.close(loadingIndex);
                            layer.msg('网络异常，请稍后再试');
                        }
                    });
                    layer.close(index);
                });
            }
        });

        // 表格工具栏点击事件（如编辑/删除）
        table.on('tool(currentTableFilter)', function (obj) {
            var data = obj.data;
            if (obj.event === 'edit') {

                var index = layer.open({
                    title: '编辑记录',
                    type: 2,
                    shade: 0.2,
                    maxmin:true,
                    shadeClose: true,
                    area: ['100%', '100%'],
                    content: 'warehouse-transfer-edit.html',
                    success: function(layero, index){
                        // 数据传递到子页面
                        var iframe = layero.find('iframe')[0].contentWindow;
                        iframe.loadData && iframe.loadData(data);
                    }
                });
                $(window).on("resize", function () {
                    layer.full(index);
                });
                return false;
            }
            else  if (obj.event === 'delete') {
                layer.confirm('真的删除这条记录吗？', function (index) {
                    $.ajax({
                        url: '/transfer/delete/' + data.id,
                        type: 'DELETE',
                        success: function (res) {
                            if (res.code === 0) {
                                layer.msg('删除成功');
                                table.reload('currentTableId');
                            } else {
                                layer.msg('删除失败：' + res.msg);
                            }
                        }
                    });
                    layer.close(index);
                });
            }
        });

    });
</script>
</body>
</html>
